草庐IT

c++ - __func__ 和日志记录

全部标签

ruby - 如何检索当前方法名称以便将其输出到记录器文件?

我正在使用RubyonRails3.2.2,为了显示开发目的的警告消息,我在我的代码中使用了logger.warn。我想检索运行logger.warn的方法名称,以便将该方法名称输出到日志文件。classClassName在我希望看到的日志文件中:IwouldliketoretrieveanddisplaytheClassName#method_name这可能吗?如果可以,我该怎么做? 最佳答案 classClassName这应该可以完成工作。 关于ruby-如何检索当前方法名称以便将其

ruby-on-rails - 如何查找上个月创建的记录?

我有一张表,每天都会添加新记录。我将如何查找上个月创建的记录? 最佳答案 设置命名范围:named_scope:in_last_month,:conditions=>["records.created_at>?",1.month.ago]调用它(在你的Controller中):Record.in_last_month 关于ruby-on-rails-如何查找上个月创建的记录?,我们在StackOverflow上找到一个类似的问题: https://stacko

ruby-on-rails - Friendly_id 不为旧记录创建 slug

我刚刚将Friendly_idgem添加到我的Rails项目中,希望不使用数据库ID并创建一个slug,但我似乎无法为旧记录创建slug。我的模型看起来像这样。classMapping然后我运行Model.find_each(&:save)但它一直吐出nil结果。我试过完全注释掉should_generate_new_friendly_id但没有成功。有人看到我在这里做错了什么吗?编辑我回滚了我的数据库并重写了我的迁移,这似乎已经解决了这个问题。 最佳答案 如果有人发现这个6年前的问题:没有“doandend”block:find_

Ruby - fork 进程上的 set_trace_func

我想实现以下目标:构建一个Ruby命令行实用程序来注册一些set_trace_func事件,然后调用您传递给它的任何ruby​​可执行参数(比如rspec)。注册的事件然后转移到调用的命令。myutility的伪代码:set_trace_func()#Setsomeeventshereexec(ARGV.join(''))#Executeargumentpassed然后调用myutilityrspec。我的目标是实际在任意命令上注册跟踪点(只要它们使用ruby​​垫片)。我尝试过的事情:exec不起作用,原因很明显(它完全取代了进程)。popen、系统、反引号。这些启动了一个独立的过程

ruby-on-rails - 无法使用 ruby​​ xmpp4r 获取以前的群聊历史记录

我正在使用ruby​​xmpp4r库通过openfire服务器实现多用户群聊应用程序。我已经成功地在openfire服务器上创建了聊天室。如果用户使用openfire凭据加入聊天室,它不会返回以前的群聊历史,它只返回几条消息,因为我正在使用add_message_callback()方法。下面是openfire群聊历史设置:**ShowEntireChatHistory(向加入房间的用户显示整个聊天记录。)--True我在这里错过了什么?任何人都有示例代码来获取以前的组历史记录? 最佳答案 我运行了一个Wildfire服务器(ope

ruby-on-rails - Rails 日志文件 "not opened for writing"

我正在将我的应用程序从ruby​​1.8.7迁移到1.9.3(然后升级Rails)。但是我在登录1.9.3时遇到了一些问题。通过在控制台或服务器启动时在environment.rb中使用以下代码logfile=File.open(File.join(RAILS_ROOT,'/log/call_log.log'),'a')CALL_LOGGER=AuditLogger.new(logfile)CALL_LOGGER.info"CALL_LOGGER:Serverstarted."我明白了/usr/local/rvm/scripts/irbrc.rb:32:in`write':notope

ruby-on-rails - 在 Rails 应用程序中记录警告(不是错误),并管理它们

我正在寻找一个好的流程来处理Rails应用程序中的警告/信息类型的消息。例如,用户输入错误密码的次数,模型验证失败的次数等。特别是,我正在寻找一种有效的方法来操作这些指标,因为它们不是异常(exception),但可能表明潜在的错误或功能方面的问题。我正在考虑的解决方案是:记录WARNING或INFO消息并使用Splunk解析它们(不幸的是Splunk非常昂贵)在WARNING环境中发送Airbrake错误 最佳答案 你应该看看Papertrail作为Splunk+Airbrake的替代品。如果您只对日志记录感兴趣,这似乎更合适。

c - Ruby 的最大函数顺序如何重复?

我一直在看maxmethod在Ruby的Enumerable混合(v2.4.1)。这是一个相当简单的方法,但是当存在重复项时它如何排序项目有点令人困惑。例如:x=[1,2,3,4,5,6,7,8,9]x.max{|a,b|a%2b%2}=>110.times{|y|px.max(y){|a,b|a%2b%2}}[][1][1,7]#whyis7thenextelementafter1?[3,1,5]#whynomore7?[7,3,1,5]#7isnowfirst[9,7,3,1,5][9,7,3,1,5,6][9,7,3,1,5,4,6][9,7,3,1,5,2,4,6][9,7,5

ruby - instance_eval 的 block 参数 - 记录了吗?目的?

刚刚意识到instance_eval产生self作为关联block的参数(除了1.9.2版本中的错误:http://www.ruby-forum.com/topic/189422)1.9.3p194:003>classC;end1.9.3p194:004>C.new.instance_eval{|*a|a}=>[#]1.9.3p194:005>这是否在某处记录/规范?看着ruby-doc:BasicObject,看不到提到的任何block参数。除了一些纯粹的历史原因之外,是否还有其他原因明确地传递它,而它自己总是被定义?我被这个击中的方式是:l=lambda{}myobj.instan

ruby-on-rails - 日志 rails 控制台总是在生产环境中归档

您可能自己知道,有时您必须通过Rails控制台在实时生产机器上执行任务...我通常这样开始:bundleexecrailsconsole-eproduction但由于它是生产机器,我想将Rails控制台的所有输入和输出记录到一个文件中,例如到/home/sshuser/myproject/console_sessions/2016_09_09__14_33_33.txt有人知道怎么做吗?我想自动启动记录器,但前提是我运行控制台?(我正在运行Rails3.2)谢谢! 最佳答案 这是一个解决方案,整个系统只有一个文件,不修改Rails项